package com.huike.web.controller.review;


import com.huike.common.core.controller.BaseController;
import com.huike.common.core.domain.AjaxResult;
import com.huike.common.core.page.TableDataInfo;
import com.huike.review.pojo.Review;
import com.huike.review.service.ReviewService;
import com.huike.review.vo.MybatisReviewVO;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

/**
 * 该Controller主要是为了复习三层架构以及Mybatis使用的，该部分接口已经放开权限，可以直接访问
 * 同学们在此处编写接口通过浏览器访问看是否能完成最简单的增删改查
 */
@RestController
@RequestMapping("/review")
public class MybatisReviewController extends BaseController {

    @Autowired
    private ReviewService reviewService;
    /**
     * =========================================================新增数据============================================
     */

    @PostMapping("/saveData")
    public AjaxResult add(@RequestBody MybatisReviewVO mybatisReviewVO) {

        //reviewService.savedate(mybatisReviewVO);

        return AjaxResult.success(reviewService.savedate(mybatisReviewVO));
    }
    @GetMapping("/saveData/{name}/{age}/{sex}")
    public AjaxResult add2(@PathVariable(value = "name", required = false) String name,
                           @PathVariable(value = "age", required = false) String age,
                           @PathVariable(value = "sex", required = false) String sex) {





        return AjaxResult.success(reviewService.savedate(name,age,sex));
    }

    /**=========================================================删除数据=============================================*/

    @DeleteMapping("/remove/{id}")
    public AjaxResult removeId(@PathVariable("id")Long id){
        return AjaxResult.success(reviewService.removeData(id));
    }
    /**=========================================================修改数据=============================================*/
    @PostMapping("/update")
    public AjaxResult update(@RequestBody MybatisReviewVO reviewVO){
        return AjaxResult.success(reviewService.updateData(reviewVO));
    }

    /**=========================================================查询数据=============================================*/
    @GetMapping("/getById")
    public AjaxResult getDataById(@RequestParam("id") Long id){
        return AjaxResult.success(reviewService.getDataById(id));
    }

    /**
     * 分页查询数据的方法
     * @return
     */
    @GetMapping("/getDataByPage")
    public TableDataInfo getDataByPage(){
        startPage();
        List<Review> list = reviewService.getDataByPage();
        return getDataTable(list);
    }
}